.el-message {
    overflow: visible;

    &__badge {
        animation: el-message-badge .42s;
        padding: 4px 8px;
        position: absolute;
        box-shadow: 0 1px 3px rgba(#000, .2), 0 1px 1px rgba(#000, .14), 0 2px 1px -1px rgba(#000, .12);
        background-color: $--color-danger;
        color: #ffffff;
        border-radius: 4px;
        top: -10px;
        left: -10px;
        font-size: 12px;
        line-height: 12px;
    }

    &__progress {
        z-index: -1;
        position: absolute;
        height: 3px;
        bottom: 0;
        left: 10px;
        right: 10px;
        animation: el-message-progress linear;
        background-color: currentColor;
        opacity: .3;
        transform-origin: 0 50%;
        transform: scaleX(0);
    }
}

@keyframes el-message-badge {
    15% {
        transform: translate3d(-25%, 0, 0) rotate3d(0, 0, 1, -5deg)
    }
    30% {
        transform: translate3d(20%, 0, 0) rotate3d(0, 0, 1, 3deg)
    }
    45% {
        transform: translate3d(-15%, 0, 0) rotate3d(0, 0, 1, -3deg)
    }
    60% {
        transform: translate3d(10%, 0, 0) rotate3d(0, 0, 1, 2deg)
    }
    75% {
        transform: translate3d(-5%, 0, 0) rotate3d(0, 0, 1, -1deg)
    }
}

@keyframes el-message-progress {
    0% {
        transform: scaleX(1)
    }
    100% {
        transform: scaleX(0)
    }
}
